<template>
  <view class="homeLayout pageBg">
    <!-- 轮播图 -->
    <view class="banner">
      <swiper
        indicator-dots
        indicator-color="#333"
        indicator-active-color="#fff"
        circular
      >
        <swiper-item v-for="item in 3">
          <image src="../../common/images/banner1.jpg" mode="aspectFill" />
        </swiper-item>
      </swiper>
    </view>
    <!-- 公告 -->
    <view class="notice">
      <view class="left">
        <uni-icons type="sound-filled" size="20"></uni-icons>
        <text class="text">公告</text>
      </view>
      <view class="center">
        <swiper vertical autoplay interval="1500" duration="300" circular>
          <swiper-item v-for="item in 4"
            >文字内容文字内容文字内容文字内容文字内容文字内容文字内容文字内容</swiper-item
          >
        </swiper>
      </view>
      <view class="right">
        <uni-icons type="right" size="16"></uni-icons>
      </view>
    </view>
    <!-- 每日推荐 -->
    <view class="select">
      <CommonTitle>
        <template #name>每日推荐</template>
        <template #custom>
          <view class="date">
            <uni-icons type="calendar" size="20"></uni-icons>
            <view class="text">
              <uni-dateformat :date="Date.now()" format="dd日"></uni-dateformat>
            </view>
          </view>
        </template>
      </CommonTitle>
      <view class="content">
        <scroll-view scroll-x>
          <view class="box" v-for="item in 4">
            <image src="../../common/images/preview1.jpg" mode="aspectFill" />
          </view>
        </scroll-view>
      </view>
    </view>
    <!-- 专题精选 -->
    <view class="theme">
      <CommonTitle>
        <template #name>专题精选</template>
        <template #custom>
          <navigator url="" class="more">More+ </navigator>
        </template>
      </CommonTitle>
      <view class="content">
        <CommonTheme v-for="item in 8"></CommonTheme>
        <CommonTheme :isMore="true"></CommonTheme>
      </view>
    </view>
  </view>
</template>

<script setup lang="ts">
import { ref } from "vue";
</script>

<style lang="scss" scoped>
.homeLayout {
  .banner {
    width: 750rpx;
    padding: 30rpx 0;
    swiper {
      width: 750rpx;
      height: 340rpx;
      &-item {
        width: 100%;
        height: 100%;
        padding: 0 30rpx;
        image {
          width: 100%;
          height: 100%;
          border-radius: 10rpx;
        }
      }
    }
  }
  .notice {
    width: 690rpx;
    height: 80rpx;
    background: #f9f9f9;
    margin: 0 auto;
    border-radius: 80rpx;
    display: flex;
    line-height: 80rpx;
    .left {
      width: 140rpx;
      display: flex;
      align-items: center;
      justify-content: center;
      :deep(){
        .uni-icons {
          color: $brand-theme-color !important;
        }
      }
      .text {
        color: $brand-theme-color;
        font-weight: 600;
        font-size: 28rpx;
      }
    }
    .center {
      flex: 1;
      swiper {
        height: 100%;
        &-item {
          height: 100%;
          font-size: 30rpx;
          color: #666;
          overflow: hidden;
          white-space: nowrap;
          text-overflow: ellipsis;
        }
      }
    }
    .right {
      width: 70rpx;
      width: 140rpx;
      display: flex;
      align-items: center;
      justify-content: center;
    }
  }
  .select {
    padding-top: 50rpx;
    .content {
      width: 720rpx;
      margin-left: 30rpx;
      margin-top: 30rpx;
      scroll-view {
        white-space: nowrap;
        .box {
          width: 200rpx;
          height: 430rpx;
          display: inline-block;
          margin-right: 15rpx;
          image {
            width: 100%;
            height: 100%;
          }
        }
        .box:last-child {
          margin-right: 30rpx;
        }
      }
    }
    .date {
      display: flex;
      align-items: center;
      color: $brand-theme-color;
      :deep(){
        .uni-icons {
          color: $brand-theme-color !important;
        }
      }
      .text {
        margin-left: 5rpx;
      }
    }
  }
  .theme {
    padding: 50rpx 0;
    .more {
      font-size: 32rpx;
      color: #888;
    }
    .content {
      margin-top: 30rpx;
      padding: 0 30rpx;
      display: grid;
      gap: 15rpx;
      grid-template-columns: repeat(3, 1fr);
    }
  }
}
</style>

